| Conditions | 1 |
| Paths | 1 |
| Total Lines | 31 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 3 | ||
| Bugs | 0 | Features | 0 |
| 1 | define(function () { |
||
| 2 | var self = this; |
||
| 3 | |||
| 4 | self.distance = function distance(a, b) { |
||
| 5 | return Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2); |
||
| 6 | }; |
||
| 7 | |||
| 8 | self.distancePoint = function distancePoint(a, b) { |
||
| 9 | return Math.sqrt(distance(a, b)); |
||
| 10 | }; |
||
| 11 | |||
| 12 | self.distanceLink = function distanceLink(p, a, b) { |
||
| 13 | /* http://stackoverflow.com/questions/849211 */ |
||
| 14 | var l2 = distance(a, b); |
||
| 15 | if (l2 === 0) { |
||
| 16 | return distance(p, a); |
||
| 17 | } |
||
| 18 | var t = ((p.x - a.x) * (b.x - a.x) + (p.y - a.y) * (b.y - a.y)) / l2; |
||
| 19 | if (t < 0) { |
||
| 20 | return distance(p, a); |
||
| 21 | } else if (t > 1) { |
||
| 22 | return distance(p, b); |
||
| 23 | } |
||
| 24 | return distancePoint(p, { |
||
| 25 | x: a.x + t * (b.x - a.x), |
||
| 26 | y: a.y + t * (b.y - a.y) |
||
| 27 | }); |
||
| 28 | }; |
||
| 29 | |||
| 30 | return self; |
||
| 31 | }); |
||
| 32 |